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server object for receiving and process- 
ing the request-type and response-type 
messages, and a specialized factory 
object for receiving the request-type 
messages from the common server ob- 
ject and creating a specialized request 

object for processing each of the re- Foctory 
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request objects includes process re- 
quest and process response methods 
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sages. In addition, the control program 

includes a receive mailbox object associated with the common server object for accessing the request-type and response-type messages 
bound for the common server object, a send mailbox object associated with the common factory object for sending the response-type 
messages to the receive mailbox object, and a message object for buffering message data included in the request-type and response-type 
messages. 
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SOFTWARE ARCHITECTURE FOR MESSAGE PROCESSING IN A 
DISTRIBUTED ARCHITECTURE COMPUTING SYSTEM 

TECHNICAL FIELD OF THE INVENTION 

This invention is related in general to the field of 
computing systems. More particularly, the invention 
relates to a software architecture for message processing 
5 in a distributed architecture computing system. 

BACKGROUND OF THE INVENTION 

Distributed computing systems require a variety of 
software and hardware components for performing processing, 

10 signaling, remote database query, administrative and other 

tasks. These components must be a capable of communicating 
with other components of the distributed architecture 
computing system across one or more interfaces. 

Conventional computing systems use a variety of 

15 techniques to communicate information between the various 

components of the system. In client /server systems, for 
example, it is not uncommon to have individually dedicated 
server processes for communicating instructions and 
information back and forth from system controllers to lower 

2 0 level system components. These server processes typically 

receive messages and perform highly specialized operations 
based on information contained in the received messages. 
Consequently, multiple message processing is severely 
impaired in conventional distributed architecture computing 

2 5 systems unless the server process provides some mechanism 

for processing messages in parallel, i.e. more than one 
request active at a time. 
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SUMMARY OF THE INVENTION 

Therefore, it is a primary object of the present 
invention to provide a common method and software 
architecture for receiving request messages, matching 
5 response messages to the corresponding request messages 

waiting for a response, and maintaining a list of active 
requests. According to an aspect of the present invention, 
the method for message processing is independent of the 
specific messages to be processed by the corresponding 

10 message server. The software architecture for message 

processing can be implemented, for example, in a 
distributed telecommunication switching system. 

It is another object of the present invention to 
provide a software architecture for message processing in 

15 a distributed architecture computing system wherein the 

support for parallel message processing is common for all 
types of message servers. 

It is yet another object of the present invention to 
provide a software architecture and method for message 

20 processing in a distributed architecture computing system 

wherein software objects, instead of functions, are used to 
process message data and perform requested operations. In 
a distributed telecommunication switching system, for 
example, a switch statement can be used to construct 

2 5 objects that process message data and execute the necessary 

switching operations. 

It is still another object of the present invention to 
provide a software architecture for message processing in 
a distributed architecture computing system wherein 

30 specialized functionality does not appear in the server 

objects, but is instead distributed at lower levels of the 
software hierarchy . 

It is still another object of the present invention to 
provide a software architecture for message processing in 

35 a distributed architecture computing system whereby a 

server object creates a factory object which defines 
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request objects for performing operations requested in 
messages received by the server object. 

It is still another object of the present invention to 
provide a software architecture for message processing in 
5 a distributed architecture computing system whereby control 

of message processing is returned to a server object after 
creation of the factory and request objects such that the 
server object is capable of processing subsequent messages. 
Further objects, features and advantages of the 

10 invention will become apparent from the following detailed 

description taken in conjunction with the accompanying 
figures showing illustrative embodiments of the invention. 

In accordance with a preferred embodiment of the 
present invention, a distributed architecture computing 

15 system is provided that includes one or more processors and 

an object-oriented control program for processing request- 
type and response-type messages provided by a messaging 
service. The request-type messages are associated with one 
or more newly requested operations, and the response- type 

2 0 messages are associated with previously requested 

operations. The control program for the computing system 
includes: a common server object for receiving and 
processing the request-type and response-type messages; a 
common factory object for receiving the request -type 

2 5 messages from the common server object and creating a 

common request object for processing each of the request- 
type messages, each of the request objects include process 
request and process response methods for performing the 
requested operation, maintaining state information 

3 0 associated with the requested operation and generating the 

response-type messages; a receive mailbox object associated 
with the common server object for accessing the request - 
type and response -type messages bound for the common server 
object; a send mailbox object associated with the common 
35 factory object for sending the response- type messages to 

the receive mailbox object; and a message object for 
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buffering message data included in the request -type and 
response- type messages . 

In accordance with another preferred embodiment of the 
present invention, a distributed telecommunications 
5 switching system is provided that includes one or more 

processors and an object-oriented control program for 
processing request -type and response-type messages provided 
by a messaging service. The request-type messages are 
associated with one or more newly requested operations, and 

10 the response-type messages are associated with previously 

requested operations. The control program for the 

computing system includes: a common server object for 
receiving and processing the request-type and response- type 
messages; a common factory object for receiving the 

15 request -type messages from the common server object and 

creating a common request object for processing each of the 
request -type messages, each of the request objects 
including process request and process response methods for 
performing the requested operation, maintaining state 

20 information associated with the requested operation and 

generating the response- type messages; a receive mailbox 
object associated with the common server . object for 
accessing the request-type and response- type messages bound 
for the common server object; a send mailbox object 

25 associated with the common factory object for sending the 

response- type messages to the receive mailbox object; and 
a message object for buffering message data included in the 
request -type and response- type messages. 

In accordance with another aspect of the present 

30 invention, a distributed architecture computing system is 

provided wherein request-type messages associated with 
requested operations are received by a common server object 
and forwarded to a factory object for processing by request 
objects. The system includes a method wherein the common 

35 server object provides the request -type messages to the 

factory object, and the factory object creates the request 
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objects for processing the request -type messages such that 
one of the request objects corresponds to one of the 
request-type messages. For each of the request-type 
messages, the corresponding request object is returned by 
5 the factory object to the common server object, which then 

invokes a process request method associated with the 
returned request object. A method is also provided when 
the common server object receives a response- type message 
and is used for matching the response- type message to the 

10 corresponding request object waiting for a response. The 

common server object invokes the request object's process 
response method which completes the processing of the 
response- type message . 

In accordance with another aspect of the present 

15 invention, a distributed telecommunications switching 

system is provided wherein request-type messages associated 
with requested operations are received by a common server 
object and forwarded to a factory object for processing by 
request objects. The system includes a method wherein the 

2 0 common server object provides the request- type messages to 

the factory object, and the factory object creates the 
request objects for processing the request -type messages 
such that one of the request objects corresponds to one of 
the request-type messages. For each of the request-type 

2 5 messages, the corresponding request object is returned by 

the factory object to the common server object, which then 
invokes a process request method associated with the 
returned request object. A method is also provided when 
the common server object receives a response- type message 

30 and is used for matching the response-type message to the 

corresponding request object waiting for a response. The 
common server object invokes the request object's process 
response method which completes the processing of the 
response- type message . 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a complete understanding of the present invention 
and the advantages thereof, reference is now made to the 
following description taken in conjunction with the 
5 accompanying drawings in which like reference numbers 

indicate like features and wherein: 

FIG. 1 shows a block diagram of a distributed 
architecture computing system utilizing a method for 
message processing according to a preferred embodiment of 
10 the present invention; 

FIG. 2 shows an object model defining the software 
architecture (building block infrastructure) for message 
processing in a distributed architecture computing system ; 

FIG. 3 shows an event trace for a sample sequence of 
15 request-type and response-type messages; 

FIG. 4 shows an inheritance diagram corresponding to 
the object model of FIG. 2; 

FIG. 5 shows a specialized server object class for use 
in a distributed telecommunications switching system 
2 0 implementation of FIG. 1; 

FIGS. 6A and 6B show an event trace corresponding to 
a sequence for processing incoming messages and timeouts; 

FIG. 7 is an event trace corresponding to a process 
timeout sequence used by a request object while waiting for 
2 5 a response- type message according to the event trace of 

FIGS. 6A and 6B; 

FIG. 8 is an event trace corresponding to sequence for 
replying to a request-type message used by the process 
timeout sequence of FIG. 7, an initial processing sequence 
30 as shown in FIG. 10, and a process response sequence as 

shown in FIG. 12; 

FIG. 9 is an event trace corresponding to a sequence 
for creating a new specialized request object according to 
the event trace of FIGS. 6A and 6B; 
35 FIG. 10 is an event trace corresponding to a sequence 

for processing a request-type message by a newly created 



WO 99/34288 



PCT/US98/27893 



7 



specialized request object according to the event trace of 
FIGS. 6A and 6B; 

FIG. 11 is an event trace corresponding to a sequence 
used by a specialized request object for allocating and 
5 sending a new specialized request message to another 

building block according to the event trace of FIG. 10; and 

FIG. 12 is an event trace corresponding to a sequence 
for matching response messages received by a server object 
with the appropriate specialized request object according 
10 to the event trace of FIGS. 6A and 6B . 

DETAILED DESCRIPTION OF THE INVENTION 

FIG. 1 is a block diagram of a computing system 10 
utilizing a method for initializing computing tasks 
15 according to a preferred embodiment of the present 

invention. As shown in FIG. 1, computing system 10 
includes a service unit layer 2 0 for top-level management 
and control of computing system 10, a delivery unit layer 
3 0 for communication and control of software elements and 

2 0 hardware components, and a communications pathway 4 0 for 

connecting service unit layer subsystems with delivery unit 
layer subsystems. Service unit layer 20 includes a top- 
level system manager 22, one or more service nodes 24 
connected to top-level system manager 22, and one or more 
25 system managers 26 also connected to top-level system 

manager 22. Delivery unit layer 30, under the control of 
service unit layer 20, includes one or more unit 
controllers 32 connected to top-level system manager 22 or 
system managers 24 via communications pathway 40, and a 

3 0 plurality of software elements, or "building blocks" 34, 

designed to be controlled by unit controllers 32, for 
performing specific computing tasks and operations. 

Computing system 10 of FIG. 1 may also include 
industry standard operating systems, object-oriented 
35 implementation, location transparent interfaces such as the 

Common Object Request Broker Architecture ("CORBA") , name- 
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based messaging services, and graphical user interfaces 
("GUI's") for system management and control. In addition, 
computing system 10 can be configured to operate as a 
telecommunications switching system such as the one 
5 disclosed in United States Patent No. 5,495,484, issued 

February 27, 1996, which is hereby incorporated by 
reference . 

In a distributed telecommunications switching system 
implementation of FIG.l, for example, service unit layer 2 0 

10 of FIG. 1 provides the functionality of the switching 

system not inherently dependent upon the technology and 
interfaces required for connecting end-users to a public 
telephony network. By contrast, delivery unit layer 3 0 
provides the functionality of the switching system directly 

15 associated with the technology and interfaces required for 

connecting end-users to a public telephony network. 
Subsystems and components included in service unit and 
delivery unit layers 20 and 3 0 are separately functioning 
subsystems which can be deployed, upgraded and maintained 

20 independently from each other, thus allowing new 

technologies and enhancements to be easily integrated into 
an existing switching system. The various service unit and 
delivery unit subsystems may be geographically co-located 
or disbursed while maintaining the distributed 

25 characteristics of the functions performed by the overall 

switching system. 

Delivery unit layer 3 0 of computing system 10 of FIG. 
1 includes hardware components, such as specialized 
application cards and processors, for providing specific 

30 telecommunication switching services. For example, in the 

above-mentioned distributed telecommunications switching 
implementation of FIG. 1, delivery unit layer 3 0 is 
designed to deliver one or more communication services to 
end-users on a public telephony network. The delivery unit 

35 hardware components may be constructed and arranged to 

perform a variety of computing tasks including but not 
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limited to configuration management, fault management, 
performance management, call processing and port management 
tasks . 

FIG. 2 shows an object model 50 defining a software 
5 architecture, i . e . r server infrastructure, for message 

processing in a distributed architecture computing system 
according to a preferred embodiment of the present 
invention. The object model includes a server object class 
52, a factory object class 54, a request object class 56, 

10 a receive mailbox object class 58, a message object class 

60 and a send mailbox object class 62. 

According to a preferred embodiment of the object 
model 50, each instance of the server object class 52 is 
responsible for receiving all incoming messages from other 

15 software applications. These messages are request -type 

messages for requesting specialized tasks or operations, or 
response-type messages for responding to previously issued 
requests. Both request-type and response-type messages 
contain header information including, by way of example and 

2 0 not limitation, a message type indicator, an operation type 

indicator, a sequence identifier and an error code 
indicator. The sequence identifier, which is unique to the 
sender of the request -type message, is used by the sender 
of the request -type message to match a response -type 

25 message to the original request. 

FIG. 3 shows an example of how the sequence identifier 
is used. The figure shows an event trace for a sample 
sequence 70 of incoming and outgoing request -type and 
response-type messages. The sample sequence 70 includes 

30 message transport between a plurality of tasks or objects 

A through D. As shown in FIG. 3, Task A requests a first 
operation from Task C by sending a first request -type 
message with sequence #18 to Task C (Event 70a) . Task C 
then sends a second request -type message with sequence #24 

35 to Task D as part of processing the first operation 

originally requested by Task A (Event 70b) . Task B then 
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requests a second operation from Task C by sending a third 
request -type message with sequence #5 to Task C {Event 
70c) . Task C then sends a fourth request-type message with 
sequence #25 to Task D as part of processing the second 
5 operation originally requested by Task B (Event 70d) . 

The sequence numbers 18, 24, 5 and 25 are then used to 
match the response- type messages with the corresponding 
request- type messages sent by Tasks A, B and C in Events 
70a through 70d. As further shown in FIG. 3, Task C 

10 receives a first response -type message from Task D and uses 

sequence #25 in the first response- type message to match 
this response with the request-type message previously sent 
by Task C to Task D (Event 70e) . Task B then receives a 
second response-type message from Task C and uses sequence 

15 #5 in the second response- type message to match this 

response with the request -type message previously sent by 
Task B to Task C (Event 70f ) . Similarly, Task C receives 
a third response- type message from Task D and uses sequence 
#24 in the third response- type message to match this 

2 0 response with the request -type message previously sent by 

Task C to Task D (Event 70g) . Task A then receives a 
fourth response -type message from Task C and uses sequence 
# 18 in the fourth response- type message to match up this 
response with the request -type message previously sent by 

25 Task A to Task C (Event 70h) . 

The processing of response- type messages, as shown by 
Events 70e through 70h of FIG. 3, utilizes an active 
request list created and maintained by the server object. 
The active request list registers and tracks active request 

30 objects awaiting responses from other objects. The active 

request objects are those objects which have been created 
as a result of the server receiving a request-type message. 
The server object searches the active request list to match 
a response -type message to the corresponding active request 

35 object. Active request objects are therefore required to 

save in their private member data the sequence identifier 



WO 99/34288 



PCT/US98/27893 



11 



for any request messages they originate. When a response- 
type message is received, the server object 52 uses the 
sequence identifier from the response- type message to match 
the sequence identifier saved in the request object private 
5 member data. 

Referring again to FIG. 2, the software architecture 
of the present invention further includes a messaging 
service (not shown) and a server object class 52 for 
receiving and processing messages from instances of the 

10 receive mailbox object class 58. The server object class 

52 is a an abstract base class for any specialized server 
object class, and contains a receive mailbox object. 

Each instance of server object class 52 contains the 
server processing loop, and has a pointer to the start of 

15 the active request list. Each server object derived from 

the server object class 52 also has the member functions 
used by the request objects to manipulate the active 
request list. Each server object "orders" a request object 
via the factory object class 54 whenever a request- type 

20 message is received, and maintains the list of "active" 

request objects. In addition, each server object may be 
associated with many instances of the request object class 
5 6 depending upon the operations supported by the server 
object. A server object class 52 is therefore capable of 

25 actively managing all associated instances of the request 

object class 56. 

According to a preferred embodiment of the present 
invention, the server object class 52 includes the 
attributes, member data and methods required for processing 

30 sequence identifiers and active request lists, allocating 

and reading the receive mailbox objects, and creating the 
factory objects used to construct the required request 
objects . 

The factory object class 54 of FIG. 2 is an abstract 
35 base class for any specialized factory object class. Each 

instance of the factory object class 54 provides the method 
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for constructing the appropriate request objects based on 
the requested operation in the received request-type 
messages. When a request- type message is forwarded from a 
server object to a factory object, the factory object 
5 processes the message and determines the operation type 

associated with the message. Based on the particular 
operation requested, the factory object constructs the 
appropriate request object corresponding to the requested 
operation. Each factory object is also associated with a 

10 send mailbox object which is used by the request objects 

for sending messages. 

The request object class 56 is an abstract base class 
for any specialized request object class. Each instance of 
the request object class 56 is responsible for adding 

15 itself to the active request list when it is created, and 

for removing itself from the active request list when the 
associated operation is completed. Each request object 
also has a pointer to the original request -type message 
that caused the request object to come into existence, and 

2 0 a pointer to the send mailbox object provided by the 

corresponding factory object that the request object uses 
for sending any new request -type messages or for replying 
to the original request -type message. Each request object 
saves the sequence identifier of any request -type message 

25 that the request originates such that the server object can 

match the response- type message with the corresponding 
request object. The request object class 56 provides 
methods to retrieve the requests, sequence identifier, send 
messages and default reply, process request and process 

30 response methods. 

Request objects derived from the request object class 
56 are also designed to implement a variety of processing 
methods including but not limited to a process request 
method, a process response method, and a reply method. The 

35 sequence identifier method is used to save the sequence 

identifiers associated with each request-type message. The 
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process request method is used for actually performing the 
requested operation, and the process response method is 
used for processing any response- type messages the request 
object may receive. The reply method is used for sending 
5 a response- type message to the original request-type 

message, and the send method is used for sending any 
request- type messages the request object originates. 

Note, if the request object does not expect to ever 
receive any response- type messages, then the process 

10 response method does not need to be implemented. In such 

a case a default process response method will take care of 
processing an error if an unexpected response is received. 

After a factory object constructs the appropriate 
request object based on the operation requested in the 

15 received request-type message, the factory object returns 

the request object to the server object. The server object 
invokes the request object's process request method, which 
contains the instructions required for processing the 
original request received by the server object. The 

2 0 process request method must save any state information 

pertaining to the processing of the request operations. If 
processing the request -type message requires that a message 
be sent to other server objects, then the request object is 
also responsible for maintaining the state information and 

25 processing any responses from the other server objects. 

Referring again to FIG. 2, if a server object derived 
from the server object class 52 retrieves a response- type 
message from the corresponding receive mailbox object, the 
server object matches the sequence identifier of the 

30 received response- type message with the corresponding 

sequence identifier on the active request list maintained 
by the server object. After the response message is 
matched with the corresponding request object on the active 
request list, the server object calls the process response 

3 5 method of that request object, which contains the 

instructions required for processing the response. 



WO 99/34288 



PCT/US98/27893 



14 

In the case where the server object receives a 
request -type message for an operation that the factory 
object does not understand, the factory object causes an 
"unknown request" request object to be returned to the 
5 server object. The "unknown request" process request 

method contains the instructions for processing unknown 
request- type message. Similarly, in the case where the 
server object receives a response- type message and the 
server object is unable to match the response- type message 

10 with a request object on the active request list, then an 

"unknown request" object is also created and returned back 
to the server object, which then invokes an associated 
"unknown request" process response method. 

Referring again to FIG. 2, the software architecture 

15 of the present invention also includes the receive mailbox 

object class 58 for reading incoming messages from the 
messaging service. The messaging service can be any 
messaging service suitable for real-time data 
communications. Instances of the receive mailbox object 

20 class 58 provide methods for reading and de-allocating 

messages provided by the messaging service. 

The send mailbox object class 62 is used for sending 
messages. The class provides methods for allocating and 
de-allocating messages, sending messages, and replying to 

25 previously received messages. In addition, the message 

object class 60 is used to contain request-type and 
response-type messages. Each instance of the message 
object class 60 includes a data buffer of a predefined, 
configurable size for writing or reading message data. 

3 0 The software architecture as shown in FIG. 2 is 

advantageous in that message processing is transparent to 
the server object. Each server object is designed such 
that the specialized processing required for each operation 
the server supports is delegated to the specialized request 

35 objects. Consequently, the software architecture of the 

present invention features a "common" server object that is 
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independent of the specialized processing to be performed. 
Specialized functionality is designed away from the server 
object class 52 and instead designed into the specialized 
factory and request classes derived from the common factory 
5 and request classes 54 and 56, respectfully. 

According to a preferred embodiment of the present 
invention, the factory objects derived from the factory 
object class 54 are specialized and designed based upon the 
message types received and operations to be performed. The 

10 request objects derived from the request class 56 are also 

specialized in that they contain the methods required to 
process the different requested operations. 

FIG. 4 is an inheritance diagram 80 that shows how the 
server infrastructure of FIG. 2 is specialized to perform 

15 specific operations or processing. As shown in FIG. 4, the 

specialized server includes a specialized server class 82 
derived from, or "inherited off," the common server object 
class 52, a specialized factory object class 84 inherited 
off the common factory object class 54, and one or more 

20 specialized request object classes 86 through 89 inherited 

off the common request object class 56. Each specialized 
request class corresponds to a specific operation supported 
by the server. The server infrastructure of FIG. 2 can be 
specialized or customized, for example, to perform specific 

25 tasks associated with one or more application cards of the 

distributed architecture computing system 10 of FIG. 1. 

FIG. 5 shows a specialized server to handle 
configuration operations for use in the distributed 

30 telecommunications switching implementation of the 

distributed architecture computing system 10 of FIG. 1. 
The configuration server shown in FIG. 5 consists of a 
configuration server 92 class, configuration factory class 
94 and several request classes 96 trough 99. The 

35 configuration server class 92, configuration factory class 

94 and request classes 92 through 99 are inherited off the 
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"common" server class 52, the factory class 54 and the 
request class 56, and are characterized by the application 
card being operated and the operations being performed. 
The specialized request classes 96 through 99 represent 
unique operations corresponding to the tasks, i . e . r 
configuration management, to be performed by a particular 
application card. The specialized request object classes 
9 6 through 99 contain all of the instructions required to 
perform the requested operation, including any state 
information pertaining to the processing of the requested 
operations . 

To further illustrate server specialization, the 
configuration server of FIG. 5 is required to perform 
configuration management operations associated with 
application card type A. As shown in FIG. 5, a specialized 
configuration server class 92 is derived from the server 
class 52, and a specialized configuration factory class 94 
is derived from the factory class 54 to construct the 
required configuration request classes 96 through 99. The 
specialized configuration request classes 96 through 9 9 are 
derived from the request class 56 to perform specific 
configuration management operations associated with 
application card A. These operations may include, for 
example, restore device, restore facility, remove device 
and remove facility configuration operations. 

Similarly, a specialized server can be customized to 
perform other tasks, such as fault management, test 
management, performance management, call processing and 
port management operations, for the same or other types of 
application cards. For example, if test management 
operations are required for application card type B, 
specialized "Test" server, factory and request object 
classes 92 through 99 are derived from the common server, 
factory and request object classes 52, 54 and 56, 
respectively, to perform the required test tasks for the 
application card B. 
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FIGS. 6A and 6B show an event trace corresponding to 
a sequence 100 for processing incoming messages and 
timeouts by a server object according to a preferred 
embodiment of the present invention. Basic server object 
5 processing includes adjusting timers associated with the 

request objects on the server object's active request list, 
processing timeouts associated with the request objects on 
the server object's active request list, processing new 
request-type or response-type messages, and calculating 

10 delay periods for receiving subsequent messages based on 

the timer values of the request objects on the server's 
active request list. As shown in further detail by FIGS. 
6A and 6B, server object processing includes Events 100a 
through 10 Op which are repeated as part of an infinite loop 

15 by an instance of the common server object class 104. 

According to a preferred embodiment of the present 
invention, an instance of a specialized server class 102 is 
derived from the common server class 104 and entered into 
the common server processing loop (Event 100a) . An 

2 0 instance of the common server maintains an active request 

list representing previously created requests awaiting a 
response. The common server object reads the next message 
from an instance of the receive mailbox class 106 
associated with the common server object (Event 100b) , and 

25 returns to the common server object a pointer to the 

received message along with an error variable, if 
applicable, to indicate the result of the read (Event 
100c) • The common server object then adjusts the timeout 
periods associated with all specialized request objects on 

30 the common server object's active request list based on the 

amount of time the common server object was blocked waiting 
for the next incoming message (Event lOOd) . 

Next, as shown by Events lOOe and lOOf, each 
specialized request object on the common server object's 

35 active request list executes a process timeout sequence 12 0 

as shown by the event trace of FIG. 7. The process timeout 
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sequence 120 of FIG. 7, together with a reply sequence 140 
as shown in FIG. 8, allows each active request object to 
determine whether a timeout has occurred while waiting for 
a response message. 
5 The remaining events lOOg through 10 Op of the common 

server object processing event sequence 100 of FIGS. 6A and 
6B are the events that occur if a valid message is received 
and no timeout is detected. As part of further server 
object processing, the common server object acquires a 

10 pointer to the start of the message data contained in the 

received message from the message object (Event lOOg) , 
which then returns the pointer back to the common server 
object such that the common server object may determine 
whether the received message is a request -type or response - 

15 type message (Event lOOh) . If the common server object 

determines that the received message is a request-type 
message, the event sequence 160 as shown in FIG. 9 is 
executed by the an instance of the specialized factory 
object class 110 to create a new specialized request object 

20 (Event 1001) . A pointer to the request object responsible 

for processing the message received is then returned to the 
common server object from the specialized factory object 
(Event lOOj), and an event sequence 180 as shown in FIG. 10 
is executed for initial processing of the newly created 

25 request object (Events 100k and 1001) . 

Referring again to FIG. 6B, if the message received by 
the common server object is not a request -type message but 
instead a response- type message, then the common server 
object finds the specialized request object on the common 

30 server object's active request list that is waiting for the 

message by matching the source sequence identifier with the 
sequence identifier of the response- type message (Event 
10 0m) . The event sequence 210 as shown in FIG. 12 is 
executed for processing the response message (Events lOOn 

3 5 and 10 Oo) . Processing control is then returned to the 

common server (Event lOOo) and the minimum timeout for the 
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currently active requests is recalculated (Event lOOp) . 
The recalculated value is used as the timeout for 
processing the next incoming message. 

FIG. 7 shows the process timeout sequence 12 0 for 
5 adjusting the timeout period for a request. FIG. 7 

corresponds to the processing steps shown by Events lOOe 
and lOOf of FIG. 6A. As shown by FIG. 7, adjustment of the 
timeout period is handled by a function within the common 
request class 112. For each of the active timers 

10 associated with the specialized request objects, a common 

request object uses the adjusted timeout period to 
decrement the individual timer values (Event 120a) . If the 
timer for a specialized request object has expired, a call 
is made to that specific request object's timeout function 

15 to process the timeout (Event 12 0b) . An event sequence 

14 0 is then executed for replying to a request -type message 
(Event 120c) , as shown in FIG. 8, and processing control is 
returned to the common request object from the specialized 
request object (Event I20d) . Processing control is then 

2 0 returned back to the common server object from the common 

request object (Event 120e) . 

FIG. 9 is an event trace corresponding to an event 
sequence 16 0 for creating a new specialized request object 
as shown by Events lOOi and 100 j of FIG. 6A. FIG. 9 shows 

2 5 how a new specialized request object is created when a 

request-type message is received. 

According to a preferred method of the present 
invention, the event sequence 160 as shown in FIG. 9 is 
used by the common server object to request that the 

30 specialized factory object construct a new request object 

that is responsible for processing the received message. 
The common server object first requests that the 
specialized factory object create the specialized request 
object (Event 160a) . If the specialized factory object 

35 supports the operation type in the request -type message, 

then the appropriate specialized request object is 
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constructed based on the operation type (Event 16 0b) . The 
specialized request object then appends itself to the 
common server object's active request list (Event 160c) and 
processing control is returned to the newly created 
5 specialized request from the common server object (Event 

16 Od) . A pointer to the newly created request object is 
then returned to the specialized factory object from the 
newly created request object (Event 160e) . 

If the specialized factory object does not support the 

10 operation type in the request-type message, then the 

specialized factory object requests that its base class, 
the common factory object class 117, construct an "unknown" 
request object to process the unsupported request (Events 
160f and 160g) . The "unknown" request object then appends 

15 itself to the common server object's active request list 

(Event 16 Oh) and processing control is returned to the 
newly created "unknown" request object from the common 
server object (Event 160i) . A pointer to the newly created 
"unknown" request object is then returned to the 

20 specialized factory object (Event 160j). Regardless of 

whether or not the requested operation is supported by the 
specialized factory object, a pointer to a specialized 
request object or "unknown" request object is always 
returned to the common server object (Event 16 0k) . 

25 FIG. 10 shows an event trace of an initial processing 

event sequence 18 0 for initially processing a newly created 
request object. FIG. 10 corresponds to the processing 
steps shown by Events 100k and 1001 of FIGS. 6A and 6B . 
According to a preferred embodiment of the present 

30 invention, the initial processing event sequence 180 of 

FIG. 10 is designed to process two scenarios: (1) where the 
requested operation can be completed within the initial 
processing stage and (2) where the request object must send 
a message to another building block and receive a response 

35 before completing processing of the requested operation. 

As further shown in FIG. 10 , in the initial processing 
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event sequence 180 for processing a newly created request 
object, the common server object begins processing of the 
requested operation by invoking the specialized request 
object's process request method (Event 180a). The 
5 specialized request object then requests a pointer from the 

"original request" message object to the message data of 
the original received request-type message (Event 180b) , 
and the pointer is returned from the "original request" 
message object to the specialized request object (Event 

10 18 0c) . If the request needs to send a message to another 

server to complete the requested operation, an event 
sequence 2 00 is executed as shown in FIG. 11 for allocating 
and sending a new request message to another building block 
(Event 180d) . Control is then returned back to the 

15 specialized request object (Event 180e) . 

If the request can complete the processing of the 
requested operation without sending messages to another 
server it does so. When the processing has been completed, 
the request sends a reply back to the sender of the 

20 request-type message by executing event sequence 140 as 

shown in FIG. 8 (Event 180f of FIG. 10) . Regardless of 
whether a new message or a reply was sent, control is 
returned back to the common server object (Event 18 Og of 
FIG. 10) . 

25 Completion of the initial processing event sequence 

18 0 of FIG. 10 therefore indicates that either the entire 
processing of the specialized request object is complete, 
i.e. , the request was a simple request, or that at least 
one additional request -type message has been sent by the 

30 specialized request object to another building block and 

the original specialized request object is waiting for a 
response before continuing processing. A simple or trivial 
request can be, for example, a request to activate a 
display light on the control panel of a certain hardware 

35 component. In such a case, the sequence 18 0 activates the 

display light and then sends the reply back to the common 
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server object that originally initiated the request. 

In any event, whether a simple or complex request is 
involved, the sequence 180 always returns control back to 
the common server object such that the server processing 
5 loop of FIGS. GA and 6B is resumed and the next message is 

processed. Therefore, after completion of the initial 
processing event sequence 180 of FIG. 10, processing 
control is returned to the common server object as shown by 
Event 1001 in FIG. 6B . 

10 FIG. 12 shows an event trace of a event sequence 210 

for processing response messages received by a common 
server object by the corresponding specialized request 
object. FIG. 12 corresponds to the processing steps shown 
by Events lOOn and lOOo of FIG. 6B . 

15 As further shown in FIG. 12, the event sequence 210 

for processing response messages includes a request by the 
common server object to some specialized request object to 
begin processing of the response- type message (Event 210a) , 
and a request (Event 210b) and return of a pointer to the 

2 0 message data of the response -type message (Event 210c) . If 

the request-type message requires that a new message be 
sent to another server to complete the requested operation, 
the event sequence 200 of FIG. 11 is executed for 
allocating and sending a new request -type message to the 
25 other server (Event 210d) . The new request-type message is 

then created and sent to the send mailbox object class, and 
processing control is returned from the send mailbox object 
to the specialized request object (Event 210e) . If the 
specialized request object can complete the requested 

3 0 operation without sending any additional request -type 

messages, then the event sequence 14 0 for replying to a 
request- type message shown in FIG. 8 is executed and 
processing control is returned back to the common server 
object (Event 210g) . 
35 After the sequence for processing the response- type 

message by the corresponding specialized request object is 
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completed, (1) the entire processing of the original 
request-type message has completed or (2) a new request- 
type message has been sent to another building block. If 
a new request -type message has been sent to another 
5 building block, then the specialized request object is 

waiting for a response before it can continue processing 
and the event sequence 210 will be repeated for each 
response- type message the common server receives for this 
request . 

10 FIG. 8 shows an event sequence 14 0 for replying to a 

request -type message used by the process timeout event 
sequence 120 of FIG. 7 (Events 120c and 120d of FIG. 7) , 
the initial processing event sequence 180 of FIG. 10 
(Events 180f and 180g of FIG. 10) and the process response 

15 event sequence 210 of FIG. 12 (Events 210f and 210g of FIG. 

12) . The event sequence 140 of FIG. 8 begins by invoking 
the reply method of the specialized request object (Event 
14 0a) , acquiring a pointer from the message object to the 
start of the message data within the original request 

20 message (Event 140b) , and returning the pointer to the 

specialized request object from the message object (Event 
140c) . If the original request-type message requires a 
reply, the specialized request object "fills-in" the data 
required for the response message and invokes the common 

25 request object's reply method (Event 140d) . 

Next, the common request object sends the response 
message (Event 140d) , sending the reply corresponding to 
the original request -type message to the send mailbox 
object from the common request object (Events 140e and 

30 140f ) , and returns processing control back to the 

specialized request (Event 140g) . The completed 

specialized request object then deletes itself (Event 
140h) , calls a request object class destructor in the 
common request object class (Event 14 Oi) , which removes the 

35 " timed-out" or completed request object from the common 

server object's active request list (Event 140j), and 
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returns processing control to the common request object 
from the common server object. If the original message did 
not require a reply then the original request message is 
deallocated from the send mailbox object (Event 1401) , 
processing control is returned to common request object 
from the send mailbox object (Event 140m) , and then to the 
removed specialized request object from common request 
object (Event 140n) . 

FIG. 11 shows an event trace of an event sequence 2 00 
used by a request object for allocating and sending a new 
request -type message to another server. FIG. 11 

corresponds to the processing steps - shown by Events 180d 
and 180e of FIG. 10 . 

As shown in FIG. 11, the event sequence 200 for 
allocating and sending a new request-type message to 
another server begins with the specialized request object 
allocating a new message from the send mailbox object 
(Event 200a) , and a pointer to the new message is returned 
to the specialized request object from the send mailbox 
object (Event 200b) . The specialized request object then 
requests a pointer to the new message data from the "new 
message" message object (Event 200c) , and the pointer is 
returned from the "new message" message object to the 
specialized request object (Event 200d) . The specialized 
request object then requests a new sequence identifier from 
the common server object (Event 2 0 0e) , which in turn 
assigns and returns to the specialized request object the 
new sequence identifier that is used to match up the 
specialized request object to corresponding response- type 
message (Event 200f ) . 

After the new sequence identifier is returned to the 
specialized request object, the specialized request object 
fills in the data for the message. As shown in FIG. 11, 
the new request -type message, including the message data 
and destination information, is requested to be sent by the 
common request object (Event 200g) . The common request 
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object converts the destination name of the new request - 
type message into an addressable message recognizable by 
the messaging service, and the addressable message is then 
forwarded to the send mailbox object corresponding to the 
5 messaging service (Event 2 00h) . The send mailbox sends the 

message and processing control is then returned to the 
common request object from the send mailbox object (Event 
200i) , and then to the specialized request object (Event 
200 j) . Finally, the new sequence identifier is saved in 

10 the request object (Event 200k) and processing control is 

returned to the specialized request object (Event 2001) . 

Referring again to FIG. 6B, Events 1001 through 100m 
always return with a pointer to a specialized request 
object of some sort even if a request message is not 

15 understood. For example, if the request message is not 

understood by the common factory object or if a matching 
specialized request object cannot be found for a response- 
type message, then this will be processed as an error 
condition, and an "unknown request" object will be returned 

20 to the common server object. The "unknown request" object 

will process these errors in its process request and 
process response methods thus relieving the common server 
object from processing these error conditions. 

Although the present invention has been described in 

25 connection with particular embodiments thereof, it is to be 

understood that such embodiments are susceptible of 
modification and variation without departing from the 
inventive concept disclosed. All such modifications and 
variations, therefore, are intended to be included within 

3 0 the spirit and scope of the appended claims. 
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WHAT IS CLAIMED IS: 

1 . A distributed architecture computing system 
having one or more processors and an object-oriented 
control program for processing request -type messages 
5 associated with one or more newly requested operations and 

response-type messages associated with previously requested 
operations, said control program comprising: 

a common server object for receiving and processing 
said request- type and response- type messages; 
10 a common factory object for receiving said request - 

type messages from said common server object and creating 
a specialized request object for each of said request-type 
messages, said specialized request object comprising 
process request and process response methods for performing 
15 said requested operations, maintaining state information 

associated with said requested operations and generating 
said response- type messages; 

a common request object associated with said 
specialized request object comprising process request, 
2 0 process response, send and reply methods for processing 

unknown request -type and response- type messages and for 
generating said request-type and response- type messages; 

a receive mailbox object associated with said common 
server object for accessing said request -type and response- 
2 5 type messages bound for said common server object; 

a send mailbox object associated with said common 
factory object for sending said response- type messages to 
said receive mailbox object; and 

a message object for buffering message data included 
30 in said request-type and response-type messages. 
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2 . The distributed architecture computing system 
according to claim 1, wherein said common server object 
comprises an active request list for matching response- type 
messages with said previously requested operations. 

5 

3 . The distributed architecture computing system 
according to claim 1, further comprising one or more 
specialized server objects for performing specific server 
tasks . 

10 

4 . The distributed architecture computing system 
according to claim 1, further comprising one or more 
specialized factory objects for performing specific factory 
tasks . 

15 

5. The distributed architecture computing system 
according to claim 1, further comprising one or more 
specialized request objects for performing specific request 
tasks . 



20 
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6 . A distributed telecommunications switching system 
having one or more processors and an object-oriented 
control program for processing request -type messages 
associated with one or more newly requested operations and 
5 response-type messages associated with previously requested 

operations, said control program comprising: 

a common server object for receiving and processing 
said request-type and response- type messages; 

a common factory object for receiving said request - 
10 type messages from said common server object and creating 

a specialized request object for each of said request-type 
messages, said specialized request object comprising 
process request and process response methods for performing 
said requested operations, maintaining state information 
15 associated with said requested operations and generating 

said response-type messages; 

a common request object associated with said 
specialized request object comprising process request, 
process response, send and reply methods for processing 
20 unknown request-type and response-type messages and for 

generating said request-type and response-type messages; 

a receive mailbox object associated with said common 
server object for accessing said request -type and response - 
type messages bound for said common server object; 
25 a send mailbox object associated with said common 

factory object for sending said response-type messages to 
said receive mailbox object; and 

a message object for buffering message data included 
in said request-type and response- type messages. 

30 
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7. The distributed telecommunications switching 
system according to claim 1, wherein said common server 
object comprises an active request list for matching 
response-type messages with said previously requested 

5 operations. 

8. The distributed telecommunications switching 
system according to claim 1, further comprising one or more 
specialized server objects for performing specific server 

10 tasks. 

9. The distributed telecommunications switching 
system according to claim 1, further comprising one or more 
specialized factory objects for performing specific factory 

15 tasks. 

10. The distributed telecommunications switching 
system according to claim 1, further comprising one or more 
specialized request objects for performing specific request 

20 tasks. 



WO 99/34288 



PCT/US98/27893 



30 

11. In a method of processing messages in a 
distributed architecture computing system, wherein request - 
type messages are provided to a common server object for 
processing, the improvement comprising: 

creating specialized request objects using a 
specialized factory object in response to said request -type 
messages, said specialized request objects including 
process request and process response methods for processing 
said request -type messages; 

invoking said process request and process response 
methods using said common server object for processing said 
request -type messages. 

12. The improvement specified in claim 11, wherein 
said common server object maintains a record of said 
specialized request objects and correlates said response- 
type messages with said specialized request objects. 

13. The improvement specified in claim 11, wherein 
said distributed architecture computing system further 
comprises one or more specialized server objects for 
performing specific server tasks, and wherein said common 
server, common factory and common request objects process 
all aspects of sending and receiving said request-type 
messages and response-type messages, and maintaining an 
active request list for matching said response- type 
messages with said corresponding request -type messages for 
any number of specialized servers regardless of the 
processing required of the specialized servers. 
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14 . In a method of processing messages in a 
distributed telecommunications switching system, wherein 
request -type messages are provided to a common server 
object for processing, the improvement comprising: 
5 creating specialized request objects using a 

specialized factory object in response to said request -type 
messages, said specialized request objects including 
process request and process response methods for processing 
said request -type messages; 
10 invoking said process request and process response 

methods using said common server object for processing said 
request-type messages. 

15. The improvement specified in claim 14, wherein 
15 said common server object maintains a record of said 

specialized request objects and correlates said response- 
type messages with said specialized request objects. 

16. The improvement specified in claim 14, wherein 
2 0 said distributed telecommunications switching system 

further comprises one or more specialized server objects 
for performing specific server tasks, and wherein said 
common server, common factory and common request objects 
process all aspects of sending and receiving said request- 
25 type messages and response-type messages, and maintaining 

an active request list for matching said response-type 
messages with said corresponding request-type messages for 
any number of specialized servers regardless of the 
processing required of the specialized servers. 
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